package Hot100.Medium.Array;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

public class LC56_MergeInterval {
    public static void main(String[] args) {

    }

    public int[][] merge(int[][] intervals){
        Arrays.sort(intervals, (p, q) -> p[0] - q[0]);
        List<int[]> ans = new ArrayList<>();
        for(int[] p : intervals){
            int m = ans.size();
            if(m > 0 && p[0] <= ans.get(m - 1)[1]){ // 相交，可以合并
                ans.get(m - 1)[1] = Math.max(ans.get(m - 1)[1], p[1]);
            } else { // 不相交，无法合并
                ans.add(p);
            }
        }
        return ans.toArray(new int [ans.size()][]);
    }
}

